热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

市面|数目_微信小程序|基于小程序+C#制作一个聊天系统

篇首语:本文由编程笔记#小编为大家整理,主要介绍了微信小程序|基于小程序+C#制作一个聊天系统相关的知识,希望对你有一定的参考价值。

篇首语:本文由编程笔记#小编为大家整理,主要介绍了微信小程序|基于小程序+C#制作一个聊天系统相关的知识,希望对你有一定的参考价值。




此文主要基于小程序+C#使用WebSocket制作一个聊天系统,基本实现小程序与服务端的聊天功能。用小程序自带的客服功能只能绑定微信且一对一沟通,接入市面上成熟的即时通讯预算又略显不足,干脆自己开发一个也能应对简单的业务场景。







    • 实现流程
      • 1、服务端
        • 1.1、项目创建
        • 1.2、设计界面
        • 1.3、服务端功能实现

      • 2、小程序
        • 2.1、小程序创建
        • 2.2、页面设计
        • 2.3、消息接收
        • 2.4、消息发送





实现流程


1、服务端


1.1、项目创建



  1. 打开Visual Studio,右侧选择创建新项目。



  1. 搜索框输入winform,选择windows窗体应用,填写对应的保存路径点击下一步,创建成功后如下图。



1.2、设计界面



  1. 在工具箱拖拽出lable文本标签修改其text属性填充标题。



  1. 拖拽textbox控件到窗体上用于输入所监听的端口号及发送的文本信息等。



  1. 接下来依次拖入button控件及listview控件实现按钮及消息面板样式。


1.3、服务端功能实现



  1. 实现websocket服务端启动功能。



双击button按钮,会生成对应的按钮事件,在事件代码中先获取端口号文本框输入的值是否正确。


int port = 9000;
if (textBox_port.Text == string.Empty)

MessageBox.Show("请填写端口", "系统提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;

try

port = Convert.ToInt32(textBox_port.Text.Trim());

catch

MessageBox.Show("请填写正确的端口", "系统提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;



在点击后,将按钮禁用,避免用户重复点击的同时开启服务端。


try

var result = _server.Open(port, "DIS");
if (result)

this.toolStripLabel_event.Text = "启动成功";
this.toolStripLabel_event.ForeColor = Color.Green;
this.toolStripLabel1.Text = "监听端口:" + port.ToString();
WSocketServer._Logger.Info("服务器启动成功");

else

this.toolStripLabel_event.Text = "启动失败";
this.toolStripLabel_event.ForeColor = Color.Red;
this.toolStripLabel1.Text = "监听端口:" + port.ToString();
button_StartListen.Enabled = true;
button_StopListen.Enabled = false;
button_Send.Enabled = false;
WSocketServer._Logger.Error("服务器启动失败");


catch (Exception ex)

WSocketServer._Logger.Error("服务器启动失败:"+ ex.ToString());



实现开启服务端的方法,这里需要对websocket的各项信息进行配置。


this.WebSocket = new WebSocketServer();
var serverConfig = new ServerConfig

Name = serverName,
MaxConnectionNumber = 10000, //最大允许的客户端连接数目,默认为100。
Mode = SocketMode.Tcp,
Port = port, //服务器监听的端口。
ClearIdleSession = false, //true或者false, 是否清除空闲会话,默认为false。
ClearIdleSessionInterval = 120,//清除空闲会话的时间间隔,默认为120,单位为秒。
ListenBacklog = 10,
ReceiveBufferSize = 64 * 1024, //用于接收数据的缓冲区大小,默认为2048。
SendBufferSize = 64 * 1024, //用户发送数据的缓冲区大小,默认为2048。
KeepAliveInterval = 1, //keep alive消息发送时间间隔。单位为秒。
KeepAliveTime = 60, //keep alive失败重试的时间间隔。单位为秒。
SyncSend = false
;
SocketServerFactory socketServerFactory = null;
//开启wss 使用证书
if (isUseCertificate)

serverConfig.Security = serverSecurity;
serverConfig.Certificate = new SuperSocket.SocketBase.Config.CertificateConfig

StoreName = serverStoreName,
StoreLocation = System.Security.Cryptography.X509Certificates.StoreLocation.LocalMachine,
Thumbprint = serverThumbprint
;
socketServerFactory = new SocketServerFactory();



  1. 实现消息发送功能。



双击发送按钮,获取客户端网络节点号向其发送数据并将发送的文本填充至消息面板。


//客户端网络节点号
string remoteEndPointStr = session.RemoteEndPoint.ToString();
if (remoteEndPointStr == s)

try

ReceiveData sendData = new ReceiveData();
//发送数据
sendData.User = "guest";
sendData.Type = "msg";
sendData.Msg = textBox_msg.Text.Trim();
sendData.SendTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
_server.SendMessage(session, JsonConvert.SerializeObject(sendData));
this.BeginInvoke(addListView, "guest", JsonConvert.SerializeObject(sendData));
MessageBox.Show("发送成功", "系统提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;

catch (Exception ex)

WSocketServer._Logger.Error(ex.ToString());
MessageBox.Show(ex.ToString(), "系统提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
return;




  1. 实现消息监听功能,接收来自客户端的数据并进行展示。

///


/// 接收到的数据
///

/// session
/// value
private void Server_MessageReceived(SuperWebSocket.WebSocketSession session, string rData)

//IP地址
string ipAddress_Receive = session.RemoteEndPoint.ToString();
if (rData.Equals(""))

//空数据不返回服务器信息
return;

try

//接收到客户端链接发送的东西
ReceiveData receiveData &#61; JsonConvert.DeserializeObject<ReceiveData>(rData);
receiveData.SendTime &#61; DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
switch (receiveData.Type)

case "HeartBeat":
//心跳
//发送客户端连接成功信息
//_server.SendMessage(session, "HeartBeat");
break;
default:
//返回用户发送数据
_server.SendMessage(session, JsonConvert.SerializeObject(receiveData));
break;


catch

WSocketServer._Logger.Error("接收异常数据:" &#43; rData);
//错误数据不反回服务器信息
return;

if (MsgFalg)

//服务端显示客户端发送接受信息
this.BeginInvoke(addListView, ipAddress_Receive, rData);



2、小程序


2.1、小程序创建



  1. 访问微信公众平台&#xff0c;点击账号注册。



  1. 选择小程序&#xff0c;并在表单填写所需的各项信息进行注册。




  1. 在开发管理选择开发设置&#xff0c;将AppID及AppSecret复制出来进行存储。



  1. 下载安装微信web开发者工具并创建一个新的项目&#xff0c;填入上图所复制的AppId。



2.2、页面设计



  1. 页面上根据发送人判断消息在哪边展示&#xff0c;同时还需要提供一个文本框以及按钮实现发送功能。

<view class&#61;"cu-chat" id&#61;"j_page">
<view class&#61;"cu-item item.User&#61;&#61;&#39;&#39;?&#39;self&#39;:&#39;&#39;" wx:for&#61;"chatData">
<view class&#61;"cu-avatar radius" style&#61;"background-image:url(../../image/cat.jpg)" wx:if&#61;"item.User&#61;&#61;&#39;guest&#39;"></view>
<view class&#61;"main">
<view class&#61;"content shadow item.User&#61;&#61;&#39;&#39;?&#39;bg-green&#39;:&#39;&#39;">
<text>item.Msg</text>
</view>
</view>
<view class&#61;"cu-avatar radius" style&#61;"background-image:url(../../image/fm3.jpg)" wx:if&#61;"item.User&#61;&#61;&#39;&#39;"></view>
<view class&#61;"date">item.SendTime</view>
</view>
</view>


  1. 通过文本框的blur事件获取用户所输入的内容。

formMsg(e)
this.setData(
content: e.detail.value.trim()
)
,

2.3、消息接收



  1. 在js的onload事件中创建websocket的连接&#xff0c;同时监听来自服务端的消息&#xff0c;端口号可以改成配置型。

let that &#61; this;
socket &#61; wx.connectSocket(
url: &#39;ws://localhost:9000/&#39;,
success: res &#61;>
//console.info(&#39;创建连接成功&#39;);

);
// console.info(socket);
//事件监听
socket.onOpen(function ()
//console.info(&#39;连接打开成功&#39;);
);
socket.onClose(function ()
//console.info(&#39;连接关闭成功&#39;);
);
socket.onError(function ()
console.info(&#39;连接报错&#39;);
);
//服务器发送监听
socket.onMessage(function (e)
console.info(JSON.parse(e.data));
var info &#61; JSON.parse(e.data);
that.setData(
chatData: that.data.chatData.concat(info)
);
// that.setData(chatData:list);
);


  1. 在监听的回调中&#xff0c;将服务端发送的文本进行打印可以看到效果如下图。




  1. 根据其格式将数据在页面上进行渲染&#xff0c;效果如下。


2.4、消息发送



  1. 发送按钮绑定自定义函数&#xff0c;获取文本框中用户输入的值&#xff0c;并通过websocket的内置函数将数据进行传输&#xff0c;这样服务端就能对数据进行接收展示。

wx.sendSocketMessage(
data: info,
success: function (res)
,
fail: function (res)


)



有兴趣的小伙伴可以在文章基础上进行拓展&#xff0c;可以增加例如群发、文件、图片发送等更加实用的功能。



推荐阅读
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文介绍了C#中生成随机数的三种方法,并分析了其中存在的问题。首先介绍了使用Random类生成随机数的默认方法,但在高并发情况下可能会出现重复的情况。接着通过循环生成了一系列随机数,进一步突显了这个问题。文章指出,随机数生成在任何编程语言中都是必备的功能,但Random类生成的随机数并不可靠。最后,提出了需要寻找其他可靠的随机数生成方法的建议。 ... [详细]
  • Metasploit攻击渗透实践
    本文介绍了Metasploit攻击渗透实践的内容和要求,包括主动攻击、针对浏览器和客户端的攻击,以及成功应用辅助模块的实践过程。其中涉及使用Hydra在不知道密码的情况下攻击metsploit2靶机获取密码,以及攻击浏览器中的tomcat服务的具体步骤。同时还讲解了爆破密码的方法和设置攻击目标主机的相关参数。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • Win10下游戏不能全屏的解决方法及兼容游戏列表
    本文介绍了Win10下游戏不能全屏的解决方法,包括修改注册表默认值和查看兼容游戏列表。同时提供了部分已经支持Win10的热门游戏列表,帮助玩家解决游戏不能全屏的问题。 ... [详细]
  • 拥抱Android Design Support Library新变化(导航视图、悬浮ActionBar)
    转载请注明明桑AndroidAndroid5.0Loollipop作为Android最重要的版本之一,为我们带来了全新的界面风格和设计语言。看起来很受欢迎࿰ ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • ASP.NET2.0数据教程之十四:使用FormView的模板
    本文介绍了在ASP.NET 2.0中使用FormView控件来实现自定义的显示外观,与GridView和DetailsView不同,FormView使用模板来呈现,可以实现不规则的外观呈现。同时还介绍了TemplateField的用法和FormView与DetailsView的区别。 ... [详细]
author-avatar
hlfk77136
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有